package cn.tedu.csmall.product.service.impl;

import cn.tedu.csmall.product.ex.ServiceException;
import cn.tedu.csmall.product.mapper.AlbumMapper;
import cn.tedu.csmall.product.mapper.PictureMapper;
import cn.tedu.csmall.product.pojo.dto.AlbumAddNewDTO;
import cn.tedu.csmall.product.pojo.dto.AlbumUpdateDTO;
import cn.tedu.csmall.product.pojo.dto.BrandUpdateDTO;
import cn.tedu.csmall.product.pojo.entity.Album;
import cn.tedu.csmall.product.pojo.entity.Brand;
import cn.tedu.csmall.product.pojo.vo.AlbumListItemVO;
import cn.tedu.csmall.product.pojo.vo.AlbumStandardVO;
import cn.tedu.csmall.product.service.IAlbumService;
import cn.tedu.csmall.product.web.JsonResult;
import cn.tedu.csmall.product.web.ServiceCode;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.List;

/**
 * 处理相册数据的业务实现类
 *
 * @author java@tedu.cn
 * @version 0.0.1
 */
@Slf4j
@Service
public class AlbumServiceImpl implements IAlbumService {

    @Autowired
    private AlbumMapper albumMapper;

    @Autowired
    private PictureMapper pictureMapper;

    public AlbumServiceImpl() {
        log.debug("创建业务对象：AlbumServiceImpl");
    }

    @Override
    public void addNew(AlbumAddNewDTO albumAddNewDTO) {
        log.debug("开始处理【添加相册】的业务，参数：{}", albumAddNewDTO);
        // 从参数对象中获取相册名称
        String albumName = albumAddNewDTO.getName();
        // 检查相册名称是否已经被占用（相册表中是否已经存在此名称的数据）
        log.debug("检查相册名称是否已经被占用");
        int count = albumMapper.countByName(albumName);
        if (count > 0) {
            // 是：相册名称已经被占用，添加相册失败，抛出异常
            String message = "相册名称已经被占用，添加相册失败";
            log.debug(message);
            throw new ServiceException(ServiceCode.ERR_CONFLICT,message);
        }

        // 否：相册名称没有被占用，则向相册表中插入数据
        log.debug("相册名称没有被占用，将向相册表中插入数据");
        Album album = new Album();

//        album.getName().toLowerCase();
        BeanUtils.copyProperties(albumAddNewDTO, album);
        log.debug("即将插入相册数据：{}", album);
        albumMapper.insert(album);
        log.debug("插入相册数据完成");
    }

    @Override
    public void delete(Long id){
        log.debug("开始处理[根据id删除相册]的业务,参数{}",id);
        // 调用Mapper对象的getStandardById()执行查询
        AlbumStandardVO standardById = albumMapper.getStandardById(id);
        // 判断查询结果是否为null
        if (standardById==null) {
            // 是：无此id对应的数据，将不允许执行删除操作，则抛出异常
            String message = "删除相册失败,尝试访问的数据不存在";
            throw new ServiceException(ServiceCode.ERR_NOT_FOUND,message);
        }

        //检查是否存在图片(picture) 关联到此相册,不许允许删除此相册
        int count = pictureMapper.countByAlbumId(id);
        if (count > 0){
            String message = "删除相册失败,此相册存在关联的图片数据";
            log.debug(message);
            throw new ServiceException(ServiceCode.ERR_CONFLICT,message);
        }

        // 调用Mapper对象的deleteById()方法执行删除
        int rows = albumMapper.deleteById(id);
        if (rows != 1 ){
            String message = "添加相册失败,服务器忙稍后再试";
            log.debug(message);
            throw  new ServiceException(ServiceCode.ERR_INSERT,message);
        }
    }

    @Override
    public List<AlbumListItemVO> list(){
        log.debug("开始处理[查询相册列表]的业务,无参数");
        return  albumMapper.list();

    }

    @Override
    public AlbumStandardVO selectById(Long id){
        log.debug("开始处理根据id查看详情的服务");
        AlbumStandardVO standardById = albumMapper.getStandardById(id);
        if (standardById == null){
            String message = "别瞎查,没有这个id";
            log.debug(message);
            throw new ServiceException(ServiceCode.ERR_NOT_FOUND,message);
        }
        return standardById;
    }

    @Override
    public void update(Long id, AlbumUpdateDTO albumUpdateDTO) {
        log.debug("开始处理【修改相册详情】的业务，参数ID：{}, 新数据：{}", id, albumUpdateDTO);
        // 检查名称是否被占用
        {
            int count = albumMapper.countByNameAndNotId(id, albumUpdateDTO.getName());
            if (count > 0) {
                String message = "修改相册详情失败，相册名称已经被占用！";
                log.warn(message);
                throw new ServiceException(ServiceCode.ERR_CONFLICT, message);
            }
        }

        // 调用Mapper对象的getDetailsById()方法执行查询
        AlbumStandardVO queryResult = albumMapper.getStandardById(id);
        // 判断查询结果是否为null
        if (queryResult == null) {
            // 是：此id对应的数据不存在，则抛出异常(ERR_NOT_FOUND)
            String message = "修改相册详情失败，尝试访问的数据不存在！";
            log.warn(message);
            throw new ServiceException(ServiceCode.ERR_NOT_FOUND, message);
        }

        Album album = new Album();
        BeanUtils.copyProperties(albumUpdateDTO, album);
        album.setId(id);

        // 修改数据
        log.debug("即将修改数据：{}", album);
        int rows = albumMapper.update(album);
        if (rows != 1) {
            String message = "修改相册详情失败，服务器忙，请稍后再次尝试！";
            log.warn(message);
            throw new ServiceException(ServiceCode.ERR_UPDATE, message);
        }
    }

}
